<template>
  <div class="app-container">
    <el-form label-width="120px">
      <el-form-item label="书籍标题">
        <el-input v-model="addData.bookName" placeholder="请输入书籍标题"  style="width:200px" />
      </el-form-item>
      <!-- 讲师头像：TODO -->
      <el-form-item label="书籍封面图片">
        <!-- 头衔缩略图 -->
        <pan-thumb :image="addData.image" />
        <!-- 文件上传按钮 -->
        <el-button
          type="primary"
          icon="el-icon-upload"
          @click="imagecropperShow = true"
          >上传图片
        </el-button>
        <!--v-show：是否显示上传组件
:key：类似于id，如果一个页面多个图片上传控件，可以做区分
:url：后台上传的url地址
@close：关闭上传组件
@crop-upload-success：上传成功后的回调 -->
        <image-cropper
          v-show="imagecropperShow"
          :width="70"
          :height="70"
          :key="imagecropperKey"
          :url="BASE_API + '/oss/upload'"
          field="file"
          @close="close"
          @crop-upload-success="cropSuccess"
        />
      </el-form-item>


      <el-form-item label="作者">
        <el-input v-model="addData.author" placeholder="作者名"  style="width:200px"/>  
        
      </el-form-item>

    <el-form-item label="图书类型">
        <el-select  filterable placeholder="请选择" v-model="addData.bookType">
          <el-option
            v-for="item in options"
            :key="item.value"
            :label="item.label"
            :value="item.value">
          </el-option>
        </el-select>
      </el-form-item>
  
      <el-form-item label="类容描述：">
        <el-input
          type="textarea"
          :rows="4"
          placeholder="请输入内容"
          v-model="addData.description"  style="width:400px">
        </el-input>
      </el-form-item>

      
      <el-form-item>
        <el-button
          :disabled="saveBtnDisabled"
          type="primary"
          @click="saveOrUpdate()"
          >保存</el-button
        >
      </el-form-item>
    </el-form>
  </div>
</template>
<script>
import releaseApi from "@/api/releaseApi";
import ImageCropper from "@/components/ImageCropper";
import PanThumb from "@/components/PanThumb";

export default {
  components: { PanThumb, ImageCropper },
  data() {
    return {   
     options: [ {
          value: '悬疑',
          label: '悬疑'
        },{
          value: '惊悚',
          label: '惊悚'
        },
        {
          value: '应用文学',
          label: '应用文学'
        },{
          value: '科幻',
          label: '科幻'
        }],
      addData: {
         id:"",
         author:"",
         bookName:"",
         bookType:"",
         description:"",
         image:""
      },
      saveBtnDisabled: false, // 保存按钮是否禁用,
      imagecropperShow: false, //头像上传组件是否显示
      imagecropperKey: 0,
      BASE_API: process.env.BASE_API, //获取dev.env.js里面的地址
    };
  },
  created() {
    //页面渲染之前执行
    this.init();
  },
  watch: {
    //监听
    $route(to, from) {
      //路由变化方式，路由发生变化，方法就会执行
      this.init();
    },
  },
  methods: {
    close() {
      //关闭上传头像组件
      this.imagecropperShow = false;
      //上传失败后，重新打开上传组件时初始化组件，否则显示上一次的上传结果
      this.imagecropperKey = this.imagecropperKey + 1;
    },
    cropSuccess(data) {
      //上传成功后返回的图片地址
      console.log(data)
      this.addData.image = data.url;
      console.log(this.addData.image);
      //上传头像成功
      this.imagecropperShow = false;
      //上传成功后，重新打开上传组件时初始化组件，否则显示上一次的上传结果
      this.imagecropperKey = this.imagecropperKey + 1;
    },
    init() {
      //判断路径有id值,做修改
      if (this.$route.params && this.$route.params.id) {
        //从路径获取id值
        const id = this.$route.params.id;
        //调用根据id查询的方法
        this.getInfo(id);
      } else {
        //路径没有id值，做添加
        //清空表单
        this.slideShow = {};
      }
    },
    //根据讲师id查询的方法
    getInfo(id) {
      activityShow.getCurrentActivity(id).then((response) => {
        console.log(response.object) 
        this.addData = response.object;
      });
    },
    saveOrUpdate() {
      //判断修改还是添加
      //根据teacher是否有id
      if (!this.addData.id) {
        //添加
        this.addbooks();
      } else {
        //修改
        this.updateActivity();
      }
    },
    //修改轮播图的方法
    updateActivity() {
      activityShow.updateActivityShow(this.addData).then((response) => {
        //提示信息
        this.$message({
          type: "success",
          message: "修改成功!",
        });
        //回到列表页面 路由跳转
        this.$router.push("/");
      });
    },
    //添加轮播图的方法
    addbooks() {
      releaseApi.addOneBooks(this.addData).then((response) => {
        //添加成功
        //提示信息
        this.$message({
          type: "success",
          message: "添加成功!",
        });
        //回到列表页面 路由跳转
        this.$router.push( "/" );
      });
    },
  },
};
</script>
